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application be accepted for examination. This patent application is a: 

new patent application; 
□ continuation in part (CIP) of Application Serial No. filed on ; 

O divisional application of Application Serial No. filed on ; 
O continuation of Application Serial No. filed on ; 

Accompanying this request is (as indicated by an "X" in the corresponding box): 
[3 1-14 pages of specification, which includes the claims and abstract, and 2 sheets 

of formal drawings; 
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□ 3 . An Information Disclosure Statement along with the references; 

D 4. A petition to extend the response for a priority application identified above; 
13 5. An assignment assigning all rights in the above referenced patent application to 
ATI International; 

13 6. An assignment recording cover sheet; 

□ 7. A verified statement establishing small entity status under 37 C.F.R. Sections 
1.9 and 1.27; 

[3 8. A certificate of mailing indicating that the above captioned patent application 
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Timothy W. Markison 
Registration No: 33,534 
Phone: (512) 343-1103 
Fax: (512) 372-3990 
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175 W. Jackson Blvd. - Suite 1015 
Chicago, Illinois 60604 
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Technical Field of the Invention 



This invention relates generally to video graphics and more particularly to 
supporting multiple displays from a single drawing surface. 
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Background of the Invention 



Computers are known to comprise of a central processing unit, system memory, 
audio processing circuitry, peripheral ports, and video processing circuitry. The 
peripheral ports allow the central processing unit to communicate with peripheral devices 
20 such as monitors, printers, external tape drives, the internet, etc. Video graphics circuitry 
functions as a co-processor to the central processing unit to perform video graphic 
functions. As such, the video graphics processor receives graphical data generated by the 
central processing unit and renders the graphical data into pixel data that is subsequently 
displayed on a monitor. 



Video graphic circuitry may be coupled to a single display or to multiple displays. 
When coupled to a single display, a frame buffer holds the pixel data that is subsequently 
provided to the display. Typically, the pixel data is mapped into the frame buffer based 
on physical parameters of the monitor (e.g., resolution and X, Y coordinates). The 
30 mapping of the frame buffer may be linear mapping or tile mapping. Regardless of the 
mapping technique, the display presents, in a full screen, the image or images stored in 
the frame buffer. 
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When the video graphics processing circuit is supplying pixel data to multiple 
displays, a primary display provides display parameters to the operating system. This 
arises because the operating system includes a single display parameter register for each 
5 video graphics controller of the computing system. As such, the operating system is not 
designed to support a video graphics controller driving two or more displays. When the 
graphics controller is driving two or more displays, all of the displays are limited to the 
display parameters of the primary display. As such, displays having capabilities that 
exceed the primary display may be disabled, or at best, limited. In addition, such an 
10 operating system does not support a virtual desktop operation. 

As is known, the virtual desktop mode enables a lower resolution display to 
display larger resolution drawing surfaces. As such, when in the virtual desktop mode, 
only a portion of the image in the frame buffer is presented on screen. To view other 
15 portions of the image, a mouse, or other GUI action is performed. However, to support 
multiple displays, and/or the virtual desktop mode, requires modification of the operating 
system interface, does not allow upgrading of the operating system without reconfiguring 
the interface, and is complex. Obviously, such intrusions on the operating system are less 
than desirable and limit commercial viability. 

20 

As is also known, a computing system may include a plurality of video graphics 
cards, or controllers, each having a separate display register associated with the operating 
system. If each card, or controller, is supporting a single display, all of the displays 
operation in full screen mode without limitations. Each card or controller, however, may 
25 support multiple displays, giving rise to the above mentioned problems. 

Therefore, a need exists for a method and apparatus that supports multiple 
displays operably coupled to a single drawing surface to support virtual desktop mode 
without the complexity or interface changes needed in current implementations and 
30 without limiting displays having greater capabilities. 
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Brief Description of the Drawing 

Figure 1 illustrates a schematic block diagram of a computing system in 
5 accordance with the present invention; 

Figure 2 illustrates a schematic block diagram of a multiple display support 
module in accordance with the present invention; and 

1 0 Figure 3 illustrates a logic diagram of method for supporting multiple displays per 

drawing surface in accordance with the present invention. 

^ Detailed Description of a Preferred Embodiment 

0 1 5 Generally, the present invention provides a method and apparatus for supporting 

^ multiple displays per a drawing surface. Such processing begins by receiving capability 

^ parameters regarding a first display of the multiple displays. The capability parameters 

3 include resolution, pixel depth, and/or refresh rate. Typically, the first display will be the 

2 primary display associated with a video graphics card. The processing continues by 

^ 20 substituting selected display capabilities for the capability parameters of the first display. 

The selected display parameters are such that it exceeds the display capability parameters 
of each display, or monitor, coupled to the video graphics card. The processing continues 
by providing the selected display capabilities to an operating system. The operating 
system then stores the selected display capabilities in the display register associated with 
25 a particular video graphics card. With such a method and apparatus, substituting the 

display parameters of a single display with all encompassing display parameters, allows a 
multitude of displays to be coupled to a single drawing surface without limiting displays 
having greater display capabilities and overcoming the intrusions into the operating 
system 

30 
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The present invention can be more fully described with reference to Figures 1 
through 3. Figure 1 illustrates a schematic block diagram of a computing system 10. 
Such a computing system 10 may be a personal computer, laptop computer, video game, 
personal digital assistant, palm top computer, hand-held computer and/or any device that 
5 performs programs and or algorithms. The computing system 10 includes a central 
processing unit 12, system memory 14, a first video graphics card 16, a second video 
graphics card 1 8, and a plurality of displays 20-26. The central processing unit 12 
includes a first video graphics register 28 and a second video graphics register 30. Each 
of these registers is operably associated with one of the video graphics cards and stores 
1 0 display capability parameters of the primary display associated with the video graphics 
card. Note that in accordance with the present invention the display capability 
parameters of a primary display will be overwritten within these registers by the selected 
display capabilities. 

1 5 The system memory 14 stores an operating system algorithm 32. As is known, 

the operating system 32 functions to start up the computing system 10 and to maintain 
operation. As part of the start-up procedure, the operating system provides inquiries to 
the video graphics cards 16 and 18 to obtain the display capability parameters of a 
primary display associated therewith. In accordance with the present invention, the video 

20 graphics card 16 and 18 will provide, during some portion of execution of the operating 
system start-up, the selected display capabilities. The providing of the selected display 
capabilities will be discussed in greater detail with reference to Figure 2 and 3. 

The video graphics card 16 is a representative schematic block diagram of the 
25 video graphics cards that may be incorporated in the computing system 10. Video 

graphics card 16 includes a drawing engine 34, a graphics driver 36, a drawing surface 
38, a first controller 40, and a second controller 42. As shown, controller 40 is operably 
coupled to display 26 and controller 42 is operably coupled to displays 22 and 24. As 
such, the video graphics card 16 supports three displays. Each of the displays may be 
30 driven from the drawing surface 38 such that they each display the same images. 
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In operation, the drawing engine 34 receives graphical data from the central 
processing unit and/or video inputs from a video decoder and processes them into RGB 
data. The graphics driver 36 receives the RGB data and coordinates the storage within 
5 the drawing surface 38. In addition, the graphics driver 36 coordinates the retrieval of the 
RGB data from the drawing surface 38 and provides it to controllers 40 and/or 42. Note 
that the central processing unit may provide the same or different graphics data to the 
video graphics cards 16 and 18. As one of average skill in the art would readily 
appreciate, the computing system 10 may include a single video graphics card that 
10 supports multiple displays and/or multiple video graphics cards that each support a single 
or multiple displays. 

Figure 2 illustrates a schematic block diagram of a multiple display support 
module 50 that includes a processing module 52 and memory 54. The multiple display 

1 5 support module 50 may be incorporated in the central processing unit and/or on the video 
graphics card. The processing module 52 may be a single processing entity or a plurality 
of processing entities. Such a processing entity may be a microprocessor, 
microcontroller, microcomputer^ digital signal processor, a portion of the central 
processing unit, digital signal processor, state machine, logic circuitry and/or any device 

20 that manipulates digital information based on operational instructions. The memory 54 
may be a single memory device or a plurality of memory devices. Such a memory device 
may be a read-only memory, random access memory, floppy disk memory, a portion of 
the system memory, CD memory, DVD memory, magnetic tape memory and/or any 
device that stores digital information. Note that if the processing module includes a state 

25 machine and/or logic circuitry to perform one or more of its functions, the memory that 
stores the corresponding operational instructions is embedded within the circuitry that 
comprises the state machine and/or logic circuitry. 

The memory 54 stores operational instructions that, when executed by the 
30 processing module causes the processing module 52 to support multiple displays per a 



6 



drawing surface. Such operational instructions may be further described with reference 
to Figure 3. 

Figure 3 illustrates a logic diagram of a method for supporting multiple displays 
5 per drawing surface. The process begins at step 60 where capability parameters 

regarding a first display are received. The receiving of the capability parameters, which 
include resolution, pixel depth, and/or refresh rate, may be received in accordance with a 
system start-up controlled by the operating system or in response to a monitor change 
process. Such a monitor change process may be, for example, switching from an LCD 
1 0 display only to an LCD and CRT display mode. 

The processing continues at step 62 where selected display capabilities are 
substituted for the capability parameters. The selected display capabilities include 
display parameters that exceed the display capabilities of each of the multiple displays 

15 coupled to the computing system 10. For example, if the computing system 10 has three 
displays coupled to a single video graphics card, where the first display has a pixel 
resolution of 640 x 480, the second 720 x 540 and the third 1024 x 768, the selected 
display capabilities would have a resolution at least as great as 1024 x 768 and may 
further be increased to 1920 x 1440 or higher. As such, the selected display capabilities 

20 may be determined based on a composite of the display parameters of each of the 
multiple displays, such an as average, a maximum display parameters, or default 
maximum display parameters. Alternatively, the selected display parameters may be 
determined based on capabilities of the video graphics card, for example, the video 
graphics card may be capable of handling a certain size display. 

25 

The process then proceeds to step 64 where the selected display capabilities are 
provided to the operating system. The operating system, upon receiving the selected 
display capabilities, causes them to be stored in a video graphics register associated with 
a particular video graphics card. 

30 
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Step 66 through 70 illustrate one possible implementation of the substitution as 
performed at step 62. At step 66, the capability parameters of the first display are 
identified as primary parameters in accordance with a first portion of the system start-up. 
As such, during the start-up and prior to boot up of the video graphics card, or boot up of 
5 a computing system, the operating system requests that each video graphics card provide 
its primary display parameters to the associated registers. The process then proceeds to 
step 68 where the capability parameters are provided to the operating system in 
accordance with the fir st portion of the system start-up. As such, the primary parameters 
are provided to the operating system and stored in the corresponding register of the 

10 operating system. The process then proceeds to step 70 where the selected display 

capabilities are identified based on the primary parameters in accordance with a second 
portion of the system start-up. The second portion of the system start-up corresponds to 
when the video graphics controller is being booted up such that it may provide the 
selected display capabilities to the associated register of the operating system thereby 

1 5 overriding the primary parameters with the selected display capabilities. 

The preceding discussion has presented a method and apparatus for supporting 
multiple displays per drawing surface. By utilizing selected display capabilities, which 
exceeds the display parameters of the displays coupled to the video graphics card, the 

20 CPU generates the graphics data based on the selected parameters. As such, the video 
graphics card, or controller, can process the graphics data such that each of the displays 
operates in full screen mode or in a virtual desktop mode. In addition, the operating 
system interface does not have to be modified to enable the virtual desktop mode and is 
done with much less complexity. As one of average skill in the art would appreciate, 

25 other embodiments of the present invention may be derived from the preceding 
discussion without deviating from the spirit of the present invention. 
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Claims 

What is claimed is: 

1 . A method for supporting multiple displays per drawing surface, the method 
5 comprises the steps of: 

a) receiving capability parameters regarding a first display of the multiple displays; 

b) substituting selected display capabilities for the capability parameters; and 

10 

c) providing the selected display capabilities to an operating system. 

2. The method of claim 1 further comprises determining the selected display 
capabilities based on a composite of the display parameters of each of the multiple 

15 displays. 



3. The method of claim 1 further comprises determining the selected display 
capabilities based on capabilities of a video graphics card. 



20 4. The method of claim 1, wherein step (a) further comprises receiving the capability 
parameters in accordance with a system start-up. 



5. The method of claim 4 ? wherein step (b) further comprises, in order,: 



25 identifying the capability parameters as primary parameters in accordance with a first 
portion of the system start-up; 



providing the capability parameters to the operating system in accordance with the first 
portion of the system start-up; and 

30 
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identifying the selected display capabilities as the primary parameters in accordance with 
a second portion of the system start-up. 

6. The method of claim 1, wherein step (a) further comprises receiving the capability 
5 parameters in response to a monitor change process. 
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7. A multiple display supporting module comprises: 

a processing module; and 

5 memory operably coupled to the processing module, wherein the memory includes 
operational instructions that cause the processing module to (a) receive capability 
parameters regarding a first display of the multiple displays; (b) substitute selected 
display capabilities for the capability parameters; and (c) provide the selected display 
capabilities to an operating system. 

10 

8. The multiple display supporting module of claim 7, wherein the memory further 
comprises operational instructions that cause the processing module to determine the 
selected display capabilities based on a composite of the display parameters of each of 
the multiple displays. 

15 

9. The multiple display supporting module of claim 7, wherein the memory further 
comprises operational instructions that cause the processing module to determine the 
selected display capabilities based on capabilities of a video graphics card. 

20 10. The multiple display supporting module of claim 7, wherein the memory further 
comprises operational instructions that cause the processing module to receive the 
capability parameters in accordance with a system start-up. 

1 1 . The multiple display supporting module of claim 10, wherein the memory further 
25 comprises operational instructions that cause the processing module to, in order,: 

identify the capability parameters as primary parameters in accordance with a first 
portion of the system start-up; 
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provide the capability parameters to the operating system in accordance with the first 
portion of the system start-up; and 

identify the selected display capabilities as the primary parameters in accordance with a 
second portion of the system start-up. 

12. The multiple display supporting module of claim 7, wherein the memory further 
comprises operational instructions that cause the processing module to receive the 
capability parameters in response to a monitor change process. 
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13. A digital storage medium for storing operational instructions that cause a 
processing module to support multiple displays associated with a drawing surface, the 
digital storage medium comprises: 



5 first storage means for storing operational instructions that cause the processing module 
to receive capability parameters regarding a first display of the multiple displays; 

second storage means for storing operational instructions that cause the processing 
module to substitute selected display capabilities for the capability parameters; and 

10 

third storage means for storing operational instructions that cause the processing module 
to provide the selected display capabilities to an operating system. 

14. The digital storage medium of claim 13 further comprises means for storing 
15 operational instructions that cause the processing module to determine the selected 

display capabilities based on a composite of the display parameters of each of the 
multiple displays. 

15. The digital storage medium of claim 13 further comprises means for storing 
20 operational instructions that cause the processing module to determine the selected 

display capabilities based on capabilities of a video graphics card. 

16. The digital storage medium of claim 13 further comprises means for storing 
operational instructions that cause the processing module to receive the capability 

25 parameters in accordance with a system start-up. 



17. The digital storage medium of claim 16 further comprises means for storing 
operational instructions that cause the processing module to, in order,: 
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identify the capability parameters as primary parameters in accordance with a first 
portion of the system start-up; 

provide the capability parameters to the operating system in accordance with the first 
5 portion of the system start-up; and 

identify the selected display capabilities as the primary parameters in accordance with a 
second portion of the system start-up. 



10 



18. The digital storage medium of claim 13 further comprises means for storing 
operational instructions that cause the processing module to receive the capability 
parameters in response to a monitor change process. 
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METHOD AND APPARATUS FOR 
SUPPORTING MULTIPLE DISPLAYS 



Abstract of the Disclosure 

5 

A method and apparatus for supporting multiple displays per a drawing surface 
begins by receiving capability parameters regarding a first display of the multiple 
displays. The capability parameters include resolution, pixel depth, and/or refresh rate. 
Typically, the first display will be the primary display associated with a video graphics 

10 card. The processing continues by substituting selected display capabilities for the 

capability parameters of the first display. The selected display parameters are such that it 
exceeds the display capability parameters of each display, or monitor, coupled to the 
video graphics card. The processing continues by providing the selected display 
capabilities to an operating system. The operating system then stores the selected display 

1 5 capabilities in the display register associated with a particular video graphics card. 
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ZIP: L3P 4K4 Country: Canada 



Name of Additional Joint Inventor: 


ZJ A petition has been filed for this unsigned inventor 


Given Name (first and middle fif any}) 


Family Name or Surname 






Inventor's 
Signature 


Date 




Residence 


Ci<y: State: 


Country: 


Citizenship: 


Post Office Address 


City: ®* t€: 


ZIP: Country: 



Given Name (first and middle fif any]) 


Family Name or Surname 






Inventor's 
Signature 


Date 




Residence 


City: State: Country: 


Citizenship: 


Post Office Address 


City: Stete: ZIP: Country; 



["[ Additional inventors are being named on the ^supplemental Additional Inventor(s) sheet(s) PTO/SB/02A attached hereto. 



